m 



WORLD INTELLECTUAL PROPERTY ORGANIZATION 
International Bureau 




PCT 

INTERNATIONAL APPUCATION PUBUSHED UNDER THE PATENT CX)OPERATION TREATY (PCT) 



(51) International Patent Classification ^ : 
GllB 27/031 



A2 



(11) International Publication Number: WO 00/00981 

(43) International Publication Date: 6 January 2000 (06.01 .00) 



(21) International Application Number: PCT/IB99/01 108 

(22) International Filing Date: 14 June 1999 (14.06.99) 



(30) Priority Data: 
9813831.6 



27 June 1998 (27.06.98) 



GB 



(71) AppUcant: KONINKLUKE PHILIPS ELECTRONICS N.V. 
[NL/NL]; Groenewoudseweg 1. NL-5621 BA Eindhoven 
(NL). 

(71) Applicant {for SE only); PHILIPS AB [SE/SE]; Kottbygatan 7. 

Kista, S-164 85 Stockholm (SE). 

(72) Inventors: ASHLEY, Alexis, S.; Prof. Holstlaan 6. NL-5656 

AA Eindhoven (NL). MORRIS. Octavius. J.; Prof. Holst- 
laan 6, NI^5656 AA Eindhoven (NL). 

(74) Agent: WHITE. Andrew, G.; Prof. Holstlaan 6, NI^5656 AA 
Eindhoven (NL). 



(81) Designated SUtes: BR, CN. JP, KR. MX, SO. VN. European 
patent (AT, BE, CH, CY, DE, DK, ES, FI. FR. GB, GR, 
IE, IT, LU, MC, NL, PT, SE). 



Published 

Without international search report and to be republished 
upon receipt of that reporu 



(54) Titte: FRAME-ACCURATE EDITING OF ENCODED AA^ SEQUENCES 



86QU8nC8 



(57) Abstract 

A method and apparatus are provided for generating bridge segments (B) to enable editing jumps to be made from one A/V segment 
(A) to another (C) whilst handling timing and frame constraints imposed by the A/V segment compliance with coding conventions such 
as MPEG. The bridge segment is constructed by copying data from the two sequences (A. C) to be bridged, with some demultiplexing 
decoding, remultiplexing and re-encoding of this data to maintain the validity of the edited data stream. Different procedures in term's 
of copying and/or ren-encoding are applied in dependence on the picture encoding types at the source and destination of the edit via the 
bridging segment. 



BEST AVAHLABLE ©Q^^Y 




FOR THE PURPOSES OF INFORMATION ONLY 
Codes used to identify States party to the PCT on the front pages of pamphlets publishing international applications under the PCX. 



AL 


Albania 


ES 


Spain 


LS 


Lesotho 


SI 


Slovenia 


AM 


Armenia 


FI 


Fmland 


LT 


Lithuania 


SK 


Slovakia 


AT 


Austria 


FR 


France 


LU 


Luxembourg 


SN 


Senegal 


AU 


Australia 


OA 


Gabon 


LV 


Latvia 


SZ 


Swaziland 


AZ 


Azerbaijan 


GB 


United Kingdom 


MC 


Monaco 


TD 


Chad 


BA 


Bosnia and Herzegovina 


GE 


Georgia 


MD 


Republic of Moldova 


TG 


Togo 


BB 


Barbados 


GH 


Ghana 


MG 


Madagascar 


TJ 


Tajikistan 


BE 


Betghun 


GN 


Guinea 


MK 


The fmmer Yugoslav 


TM 


Turkmenistan 


BF 


Burkina Paso 


GR 


Greece 




Republic of Macedonia 


TR 


Ttokey 


BG 


Bulgaria 


HU 


Hungary 


ML 


Mali 


TT 


Trinidad and Tobago 


BJ 


Benin 


IE 


Ireland 


MN 


Mongolia 


UA 


Ukraine 


BR 


Bnzil 


IL 


Israel 


MR 


Mauritania 


UG 


Uganda 


BY 


Belarus 


IS 


Iceland 


MW 


Malawi 


US 


United States of America 


CA 


Canada 


IT 


Italy 


MX 


Mexico 


uz 


Uzbekistan 


CF 


Central African Republic 


JP 


Japan 


NE 


Niger 


VN 


Viet Nam 


CG 


Congo 


KE 


Kenya 


NL 


Netherlands 


YU 


Yugoslavia 


CH 


Switzerland 


KG 


Kyrgyzstan 


NO 


Norway 


ZW 


Zimbabwe 


CI 


Cdte d'lvoiie 


KP 


Democratic People's 


NZ 


New Zealand 






CM 


Cameroon 




R^blic of Korea 


PL 


Poland 






CN 


China 


KR 


Republic of Korea 


PT 


Portugal 






CU 


Cuba 


KZ 


Kazakstan 


RO 


Romania 






CZ 


Czech Republic 


LC 


Saint Lucia 


RU 


Russian Federation 






DE 


Gennany 


U 


Liechtenstein 


SD 


Sudan 






DK 


Denmark 


LK 


Sri Lanka 


SE 


Sweden 






EE 


Estonia 


LR 


Liberia 


SG 


Singapore 








wo 00/00981 PCT/IB99/01 108 

1 



DESCRIPTION 

FRAME-ACCURATE EDITING OF ENCODED SEQUENCES 

5 The present invention relates to the storage, retrieval and editing of 

frame-based coded audio and/or video data particularly, but not 
essentially, in conjunction with optical disc storage for the data and the use 
of MPEG-compliant coding schemes. 

10 In recent times, a need has arisen for both domestic and 

commercial audio and/or video (herein "AA/") apparatuses to support a 
greater amount of user interactivity, and arising from this is a need for 
seamless joining of AA/ segments in which the transition between the end 
of one segment and the start of the next may be handled smoothly by the 

15 decoder. This implies that from the user's point of view there is no 
perceptible change in the viewed frame rate and the audio continues 
uninterrupted. Applications for seamless video are numerous, with 
particular domestic uses including the editing of home movies and the 
removal of commercial breaks and other discontinuities in recorded 

20 broadcast material. Further examples include, video sequence 
backgrounds for sprites (computer generated images); an example use of 
this technique would be an animated character running in front of an 
MPEG coded video sequence. Another is a series of character-user 
interactions presented as short seamless clips where the outcome of an 

25 interaction will determine which clip appears next. A development of this is 
interactive motion pictures where the user (viewer), can influence the 
storyline. Branch points along the path a user chooses to take through the 
interactive movie should appear seamless, othenA^ise the user will lose the 
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suspension of disbelief nomnally associated with watching a movie. 

A problem with frame-based coding schemes, in particular those 
such as the MPEG-compliant schemes involving predictive encoding 
between frames for at least the video content, is that it is not possible to 
5 simply jump from the last frame in a first group of pictures (GOP) to the 
first frame of a new GOP, let alone from one arbitrarily selected frame to 
another. This is due to temporal dependencies, timing and buffering 
constraints among others, as will be discussed further hereinafter. 

10 It is therefore an object of the present invention to enable readout of 

stored audio and/or video clips or frame sequences in a way which allows 
them to be joined without causing perceptible disturbances. 

In accordance with the present invention there is provided a data 
processing apparatus comprising means operable to read sequences of 

1 5 frame-based data from a storage device and to edit the same, such as to 
link from a first edit point in a first fi^me sequence to a second edit point in 
a second sequence, wherein for each of the stored frame sequences a 
number of the frames (hereinafter referred to as "l-frames") are intra- 
coded, without reference to any other frame of the sequence, a number 

20 (hereinafter referred to as "P-frames") are respectively coded with 
reference to one further frame of the sequence, and the remainder 
(hereinafter referred to as "B-frames") are respectively coded with 
reference to two or more further frames of the sequence; the apparatus 
including bridge generation means configured to create a bridge frame 

25 sequence to link the first and second edit points, by selective incorporation 
of frames from the stored first and second frame sequences and selective 
receding of one or more of the frames within the bridge sequence as 
determined by the coding type (I, P, or B) of the frames from the first and 
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second sequences indicated by the respective edit points. 

Also in accordance with the present invention there is provided a 
method idr editing sequences of frame-based data such as to link from a 
first edit point in a first frame sequence to a second edit point in a second 
5 sequence, wherein for each of the frame sequences a number of the 
frames (hereinafter "l-frames") are intra-coded, without reference to any 
other frame of the sequence, a number (hereinafter "P-frames")are 
respectively coded with reference to one further frame of the sequence, 
and the remainder (hereinafter "B-frames") are respectively coded with 

10 reference to two or more further frames of the sequence; the method 
including the step of creating a bridge frame sequence to link the first and 
second edit points, the bridge frame sequence incorporating frames from 
the first and second frame sequences with' selective receding of frames 
within the bridge sequence being detennined by the coding type of the 

1 5 frames from the first and second sequences indicated by the respective 
edit points. 

By use of the bridge sequence generation, which may be effected 
by a suitably configured subsection of a signal processing apparatus 
handling data transfer to and from the storage device, a means is provided 
20 to address the problem of making video- and/or audio-frame accurate edits 
in MPEG-compliant and similar program streams where, because of the 
temporal dependencies and buffering models used in such coding and 
multiplexing techniques, simple cut-and-paste edits cannot be made at any 
frame boundary. 

25 Further features of the present invention are recited in the attached 

claims, the disclosure of which is incorporated herein by reference, and to 
which the readers attention is now directed. These and other aspects of 
the invention are further described in terms of exemplary, but non-limiting. 
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embodiments below. 

Preferred embodiments will now be described by way of example 
only, and with reference to the accompanying drawings in which: 

Figure 1 is a block schematic representation of an optical disc 
5 record/reply apparatus suitable to embody the invention; 

Figure 2 is a more detailed schematic showing components within 
the apparatus of Figure 1 ; 

Figure 3 represents the recording of blocks of infomnation In 
sequence areas on an optical disc; 
10 Figure 4 represents the playback of information stored on the disc 

in Figure 3; 

Figure 5 generally illustrates the editing of stored video data, with 
bridge sequences omitted; 

Figure 6 represents the required splice points for a pair of MPEG 
1 5 video picture streams in presentation order; 

Figure 7 illustrates sequence boundaries in relation to a generated 
bridge sequence; 

Figure 8 schematically represents differences in duration of video 
and audio signal frames and their relation to data pack size; 
20 Figure 9 represents the creation of a bridge segment between two 

AA/ frame sequences; and 

Figure 10 illustrates audio packet lag in a compound AN packet 
stream. 

25 The following description considers in particular AA/ devices 

operating according to the MPEG standards (ISO/IEC 11172 for MPEG1 
and, in particular, ISO/IEC 13818 for MPEG2) although the skilled 
practitioner will recognise the applicability of the present invention to other 
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AN cx>ding schemes not in confomiance with the MPEG standard. 

The following describes how the present invention addresses the 
problem of making video- and/or audio-frame accurate edits in an MPEG 
Program Stream where, because of the temporal dependencies and 
5 buffering models used in MPEG coding and multiplexing, simple cut-and- 
paste edits cannot be made at any frame boundary. 

In order to facilitate editing, bridge sequences are generated - that 
is to say short sequences of MPEG data that are especially constructed (in 
a manner to be described) to link together two original recordings of 

10 MPEG data. As will be described, in certain circumstances, it becomes 
necessary to partially decode and re-encode sections of this data in order 
to construct a valid MPEG stream. 

The final element in the video edit is a control stmcture or play list 
This instructs the play-back isystem how to sequence through the streams. 

1 5 It contains the outrpoint from the original stream and information about the 
start of the bridge sequence. It contains information about where to jump 
into the second stream from the end of the bridge sequence. It may also 
contain other information to make management of the play back easier, i 
Figure 1 shows an embodiment of an apparatus suitable to host the 

20 present invention, in the form of an optical disc record and playback 
device. In the description of the apparatus, the handling of frame-based 
video signals is concentrated upon, although it will be recognised that 
other types of signal may alternately or additionally be processed, such as 
audio or data signals, and that the invention is equally applicable to other 

25 memory devices such as magnetic data storage means and computer 
hard disc drives. 

The apparatus comprises an input terminal 1 for receiving a video 
signal to be recorded on optical disc 3. Further, the apparatus comprises 
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an output terminal 2 for supplying a video signal reproduced from the disc. 

The data area of the disc 3 consists of a contiguous range of 
physical sectors, having corresponding sector addresses. This address 
space is divided into sequence areas, with a sequence area being a 
5 contiguous sequence of sectors. The apparatus as shown in Figure 1 is 
decomposed into two major system parts, namely the disc subsystem 6 
and what is referred to herein as the video recorder subsystem 8 
controlling both recording and playback. The two subsystems are 
characterised by a number of features, as will be readily understood, 

10 including that the disc subsystem can be addressed transparently in temis 
of logical addresses and can guarantee a maximum sustainable bitrate for 
reading and/or writing. 

Figure 2 shows a schematic version of the apparatus in more detail. 
The apparatus comprises a signal processing unit 100 which is 

15 incorporated in the subsystem 8 of Figure 1. The signal processing unit 
100 receives the video signal via the input terminal 1 and processes the 
video data into a channel signal for recording on the disc 3. A read/write 
unit indicated by dashed line 102 is provided, incorporated in the disc 
subsystem 6 of Figure 1. The read/write unit 102 comprises a read/write 

20 head 104 configured for reading from/writing to optical disc 3. Positioning 
means 106 are present for positioning the head 104 in a radial direction 
across the disc 3. A read/write amplifier 108 is present in order to amplify 
the signals to and from the disc 3. A motor 110 rotates the disc 3 in 
response to a motor control signal supplied by signal generation unit 112. 

25 A microprocessor 114 is present for controlling all the circuits via control 
lines 116, 118, and 120. 

The signal processing unit 100 is adapted to convert the video data 
received via the input terminal 1 into blocks of information in the channel 
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signal: the size of the blocks of information can be variable but may (for 
example) be between 2MB and 4MB. The write unit 102 is adapted to 
write a block of information of the channel signal in a sequence area on 
the disc 3. The infomnation blocks corresponding to the original video 
5 signal are written into many sequence areas that are not necessarily 
contiguous, as may be seen in the recording diagram of Figure 3, which 
arrangement is known as fragmented recording, it is a characteristic of the 
disc sub-system that it is able to record and write such fragmented 
recordings fast enough to meet real-time deadlines. 

10 In order to enable editing of the video data recorded in an eariier 

recording step on the disc 3, the apparatuses further provided with an 
input unit 130 for receiving an exit position (out-point) In a first video signal 
recorded on the disc 3 and - for . receiving an entry position (inpoint) in. a 
second video signal recorded on that same disc. Additionally, the ^ 

15 apparatus comprises a. bridging sequence generating unit 134/ 
incorporated in the signal processing unit 100, for generating the bridging 
sequence to link the two video streams as is described in detail 
hereinafter. 

Recording of a video signal will be briefly discussed with reference 
20 to Figure 3. In the video recorder subsystem, the video signal, which is a 
real time signal, is converted into a real-time file RTF as shown in the 
upper part of Figure 3. The real-time file consists of a succession of signal 
block sequences SEQ for recording in corresponding (although 
fragmented) sequence areas. There is no constraint on the location of the 
25 sequence areas on the disc and, hence, any two consecutive sequence 
areas comprising portions of data of the video signal recorded may be 
anywhere in the logical address space LAS as shown in the lower part of 
Figure 3. Within each sequence area, real time data is allocated 
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contiguously. Each real time file represents a single AA/ stream. The data 
of the A/V stream is obtained by concatenating the sequence data in the 
order of the file sequence. 

Next, playback of a video signal recorded on the disc 3 will be 
5 briefly discussed with reference to Figure 4. Playback of a video signal is 
controlled by means of a playback control (PBC) program. In general, 
each PBC program defines a new playback sequence PBS, which may 
comprise an edited version of recorded video and/or audio segments, and 
may specify a sequence of segments from respective sequence areas. As 

10 may be seen from comparison of Figures 3 and 4. the PBC required to 
recreate the original file sequence (from Figure 3) re-orders the 
fragmented recorded segments to provide a playback frame succession 
corresponding to the original sequence. 

The editing of one or more video signals recorded on the disc 3 is 

15 discussed with reference to Figure 5, which shows two video signals 
indicated by two sequences of fragments named "file A" and "file B". For 
realising an edited version of one or more video signals recorded eariier, a 
new PBC program is generated for defining the AA/ sequence obtained by 
concatenating parts from eariier AA/ recordings in a new order. The parts 

20 may be from the same recording or from different recordings. In order to 
play back a PBC program, data from various parts of (one or more) real 
time files has to be delivered to a decoder. This implies a new data stream 
that is obtained by concatenating parts of the streams represented by 
each real-time file. In Figure 5, this is illustrated for a PBC program that 

25 uses three parts, one from file A and two from file B. 

Figure 5 shows the edited version starts at a point P1 in the 
succession of areas of file A and continues until point P2 in the next 
sequence area of file A. Then reproduction jumps over to the point P3 in 
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the sequence area in file B and continues until point P4 in a further 
sequence area in file B. Next reproduction jumps over to the point P5 in 
the same file B. which may be a point earlier in the succession of 
sequence areas of file B than the point P3, or a point later in the 
5 succession than the point P4. From the point P5 in the sequence area in 
file B reproduction continues until point P6. The generation of bridge 
sequences for the transitions P2-P3 and P4-P5 has been omitted ft-om 
Figure 5 for reasons of clarity: the reasons for, and means for generation 
of, these bridge sequences will now be considered. 
10 As will be generally understood, the following examples relate to 

frame-based rather than field-based editing: this is because the general 
unit of video encoding in MPEG is the frame. It will be recognised by the'^'- 
skilled person that MPEG compliance is not mandatory (as mentioned'^^' 
above) and that the techniques described herein may be also applied to**^' 
15 non-MPEG field-based data. 

In order to create a seamless edit from one MPEG stream to 
another using a bridge sequence, a number of factors and conditions have - 
to be observed, as summarised below and considered in detail hereinafter. 

Beginning with the elementary streams, and considering first the 
20 video issues: 

Field sequence: the sequence (top-bottom) must be preserved 
across all jumps, into or out from the bridge sequence. 

Resolution change: if there is a change in resolution, seamless 
playback can be guaranteed if required. The apparatus can be simplified if 
25 a limited number of pemiissible resolution levels (e.g. half or full) can be 
used. 

3:2 pull-down: the field sequence (top-bottom) must be presented 
across all jumps. 
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Mixed frame rates(e.g. from NTSC or PAL): in these circumstances, 
seamless playback can only be guaranteed with additional cost and 
complexity to the apparatus, as this mixing requires a change of vertical 
sync for the display. Such mixing of standards and hence frame rates 
5 should therefore be avoided wherever possible. 

Picture types: different operations will be required depending on the 
picture type (l,P,B) involved, as discussed below. 

Turning now to the audio issues, the first is that of gaps. For an edit 
in a combined AN stream, the join will generally be seamless in video, but 
10 there may be a discontinuity in the audio frame structure - either in the 
form of a gap or an overlap, due to audio frames generally being of 
different duration to video frames. To handle this, information is needed in 
the playlist to help player control. Another audio issue is that of frame 
structure, with it being the responsibility of the creator of the bridge 
1 5 sequence to ensure that a continuous sequence of complete audio frames 
is presented to the decoder. 

Considering multiplex issues, jumps in the System Clock 
Reference (SCR) time-base can happen at any frame boundary at the 
connection, and consequently the decoder has to be able to reconstruct 
20 the correct time-base. Additionally, across all seamless jumps, System 
Target Decoder (STD) bounds must be respected, with it being the 
responsibility of the process that creates a bridge sequence to ensure this. 
From multiplexing, the issue of audio skew arises: in a typical 
implementation there will be a skew between the arrival times of 
25 concurrently decoded audio and video. To handle this, the decoder must 
have the facility for reading additional frames of audio from the multiplexed 
stream before a jump can be made. 

Finally, the principal disc buffering issue is that of allocation 
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requirements, with it being the responsibility of the process that creates the 
edit to ensure that the requirements for minimum contiguous areas are 
met. 

As previously suggested, connections in temris of decoding and 
5 presentation of the video stream are to be made seamlessly, as generally 
illustrated in Figure 6. Therefore, unnecessary pictures after the out-point 
or before the in-point are excluded during a process that re-encodes a part 
of the sequences around the edit point. Continuous supply of data is a 
precondition for the seamless decoding, which supply must be guaranteed 

10 by the file system. 

At the end of a sequence before the connection (SEQ.1). an MPEG 
End of Sequence code is placed and at the start of the sequence after the ' 
connection point (SEQ.2) there is a sequence header. The video material ^ 
at the erid of SEQ.1 and the start of SEQ.2 is likely to need to be re^ ^ 

15 encoded. As shown in Figure 7. the connection is made by creating a 
video bridge sequence. The bridge sequence consists of re-encbded 
video from the original content on either side of the out-point and in-point. 
The first part of the bridge forms the end of SEQ.1 . It is a piece of coded 
video up to and including the intended out-point. It is re-encoded to 

20 connect to the previous frames of SEQ.1 and fomi a continuous, compliant 
elementary stream. Similariy, the second part of the bridge fonris the head 
of SEQ.2. It consists of coded data from the in-point in SEQ.2 onwards. 
This data is re-encoded to give an effective start point for decoding, and to 
connect to the rest of SEQ.2 to fomi a continuous, compliant elementary 

25 stream. The video-bridge contains the connection between the two 
sequences. All video data in SEQ.1 and SEQ.2 is compliant with the 
MPEG- Video specification, with SEQ.2 starting with an l-picture and GOP 
header. The l-picture is the first presentation unit in that GOP (temporal 
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reference = 0). This ensures that there is a "clean break" between the 
video data of the sequence, and means that the last byte of video data 
from SEQ.1 is delivered before any bytes of video data from SEQ.2 are 
delivered. Additional restrictions imposed include that the video 
5 presentation units defined in the bit-stream shall be continuous across the 
connection, with neither frame nor field gaps in the presentation at the 
connection. 

In temis of audio, the difference in video and audio frame sizes can 
lead to a gap in the sequence of audio presentation units at a connection. 

10 Although a gap of less than one audio frame duration may be tolerated, it 
is preferred to insert a further audio frame at this point such that there is an 
overlap in the definition of audio presentation units of less than one audio 
frame period. For multiplexing issues, the end of SEQ.1 and the start of 
SEQ.2, the sections that form the bridge sequence are re-encoded and 

1 5 remultiplexed and stored in a multiplex-bridge to ensure that a STD model 
is obeyed. To meet the requirements of this STD model, the multiplex 
bridge is likely to be longer in time than the bridge sequence. The timing 
of all presentation units before, during and after the connection point is 
detemnined by a single reference time-line such that in the play-back 

20 model the connection is seamless. 

For file allocation, the connection is constructed so that continuous 
supply of data is guaranteed by the file system. This is done by allocating 
the multiplex-bridge as part of a new allocation that is connected to the 
bodies of SEQ.1 and SEQ.2. Choosing the jump point out of the original 

25 data in SEQ.1 to a new allocation containing the end of SEQ.1 to satisfy 
conditions on allocation of contiguous blocks of data to enable real-time 
supply of data, the new allocation must at least contain the multiplex- 
bridge. This new allocation may be longer than the multiplex-bridge if 
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required. The length of the bridge allocation (containing the end of SEQ.1 
and the start of SEQ.2. including the multiplex-bridge) should be chosen to 
satisfy conditions on the permissible extent of such fragments, and the 
point at which SEQ.2 jumps back to the original data sequence should be 
5 chosen to satisfy the above-mentioned condition on the allocation of 
contiguous blocks. 

It should be noted that the jump points near the end of SEQ.1 and 
near the start of SEQ.2 are not directly linked to the start and end of the 
multiplex-bridge. They should be chosen by the system creating the edit 
1 0 to meet the allocation rules. It is always possible to chose jump points to 
meet the continuous supply conditions for an arbitrary choice of edit in- 
and out-point. 

At the video sequence level, frames can either be copied from the- 
original sequence or decoded and then re-encoded to form the bridged 
1 5 sequence. The decision as to whether to re-encode (for improved quality): ' 
or copy (for improved speed) relies on one of several reasons: 

Re-encoding may be unavoidable because the reference picture ^ 
used is no longer present; < ■ 

Re-encoding is indicated because the reference picture has 
20 changed, but because it is the same picture content (although re-encoded) 
it may be decided to copy rather than re-encode, trading accuracy for 
speed; 

Re-encoding is chosen in order to reduce the bit-rate. 
There are a few combinations of cases that have to be considered. 
25 as will be described below. In these examples, the letters I, P, and B have 
their conventional meanings in terms of MPEG picture or frame types; the 
subscript numerals following the frame-type letters indicate the frame 
display order, the subscript letters indicate source or destination, and the 
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bold type face identifies the particular frame illustrating the current 
example. 

The first example has the source picture (frame in the first 
sequence) to jump out from as a B-picture. 
5 In display order: 

losBisB2sP3sB4sB58PesB7sBBsP9sBlOsBl Is 

In bit-stream order: 

10 

'0sB-isB.2sP3sBisB2sP6sB4sB5sP9s^8B8s 

If the jump is direct from frame Bgs, the decoder will incorrectly display Pes- 
Therefore, if the edit-out point is a B-picture, the jump must be made on 
15 the previous (display order) P-picture and recede the B-pictures in the 
bridge sequence. The sequence of pictures up to the out point is then: 

losB.,3B.2sP3sBisB2s REF_PIC B'ss 

20 where REF_PIC is a reference (I or P) picture taken from the destination 
stream, and 8*45 correspond in picture content to source stream 
firames 645 and 855 but are re-encoded based on the new reference picture. 

In an alternative arrangement, to ensure a "clean break" connection 
as explained above, the picture coding type of 8*43 should be changed to 

25 P-frame so that the injection into the source sequence of REF_PIC from 
the destination sequence is avoided. With this change, the sequence of 
pictures up to the out point becomes: 
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'08B.1sB.2sP3sBlsB28P 4S B59 

In the next example, the source picture to jump out from is a P- or I- 
picture. In display order, the original sequence is: 

5 

In bit-stream order: 

1 0 losB-l8B.2sP3sB,8B2sP6sB4sB5sP9sB78B8s 

If the out point is Pes, then the jump is made after 853 in bit-stream order. 
All pictures in the sequence jumped out from will decode correctly and can 
therefore be simply copied. The case is the same for an l-picture instead 
15 of a P-plcture. 

In the third example, the destination picture to jump to is a B- 
picture. In display order the original destination sequence is: 

lodBidB2dP3dB4dB5dP6dB7dB8dP9dBiOdBiid 

20 

In bit-stream order the original destination sequence is: 

lodB.idB.2dP3dBic|B2dP6dB4(|B5j,P9dB7(,B8j, 

25 The composite bridge sequence is: 
XXXXXXXX PgdB4(jB5dPgfjB7^B8(j 
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where the X's are the pictures copied or re-encoded from the source 
sequence. There are two cases (depending on whether we jump on an I- 
/P-picture or a B-picture. as above) with the respective following 
possibilities for the XXX stream: 

5 

losB.isB.2sP3sBisB2s REF.PIC B'43 B*58 

losB-i5B.2sP3sBlsB2sP68B4sB5s 

In either case Pea needs to be re-encoded as it has lost its reference 
10 picture; 84^, must be removed from the sequence; 6^ must be re-encoded; 
and Psd and all other pictures in the GOP (Group of Pictures) should be re- 
encoded because Pgd has been re-encoded. Normally however it may be 
possible to simply copy Pga and accept limited quality degradation caused 
by mismatch, although all pictures after the splice may need the temporal 
15 reference to be changed. Again, in order to preserve the clean break at 
the connection, we can re-encode and change the picture type of Pgs to I- 
frame. B4 must be excluded and 85 is re-encoded. Again, all frames 
should be re-encoded, but it may be deemed sufficient to simply 
recalculate the temporal references. 
20 The last of these examples considers the case where the 

destination picture to jump to is an I- or P-picture. In display order the 
original destination sequence is: 

lodBidB2<,P3dB4<jB5dP6dB7dB8dP9(lBiod8iidPl2dBi3dBi4dPl5ci 

25 

In bit-stream order the original destination sequence is: 

lodB.-,d8.2dP3dBldB2dP6dB4dB5dP9dB7dB8dPl2dBlOdBiidPl5dBl3dBl4d 
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The composite bridge sequence is: 

XXXXXXXX P9c|B7d^8d^l2d^l0dBlld 

5 

where the X's are the pictures copied or re-encoded from the source 
sequence. As before, there are two cases, depending on whether we 
jump on an l/P or a B-picture, with the following generalised possibilities 
for the XXX stream: 

10 

I0SB.13B.23P3SB13B23 REF_PIC 8*53 
'osB.isB.2sP3sBisB2sPesB4sB5s 

In either case P^ needs to be re-encoded as it has lost its reference ' ' 
1 5 picture, 67^ and must be removed from the sequence as neither are 
relevant to the edited stream, and P^^a and all other pictures in the GOP 
should be re-encoded because Pg^has been re-encoded: however, it may" 
be possible to simply copy P^za and accept limited quality degradation^ 
caused by the mismatch, although all pictures after the splice may need 
20 the temporal reference to be changed. As described above, in the first 
option REF__PIC may be replaced by changing the frame type of to 
preserve the clean break. 

Turning to the field sequence, this must be preserved across a 
seamless join. Normally with frame-structured coding without using 3:2 
25 pulldown this is the default action when edits are based on frames or field- 
pairs. In case repeat_first_field (rff) and top_field_first (tff) flags are used 
(MPEG-standard encoder options) then care is needed to ensure field 
dominance preservation. This will be made easier if every coded picture is 
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time-stamped DTS/PTS (Decoding Time Stamp/Presentation Time 
Stamp). In case they are not time-stamped it is necessary to lool< at the rff 
and tff flags to detemiine the field sequence. This is a further criterion that 
must be met on a jump. 
5 In order to give the "clean break" at the edit points, the multiplexing 

is constrained so that all data for SEQ.1 is delivered to the input of the 
STD before the first data for SEQ.2 is delivered. This gives a single 
discontinuity point in the supplied data. Note that both SEQ.1 and SEQ.2 
when considered independently may suitably (although not essentially) 
10 comply with ISO/IEC 13818-1 P-STD, although other multiplexing methods 
may be used. The coding and multiplexing of video packs in both SEQ.1 
and SEQ.2 are constrained for buffering continuity, as will be described 
below. 

The last audio packet of an audio stream in SEQ.1 contains the 
15 sample that has a presentation interval that includes the end of the 
presentation period of the last video picture in SEQ.1. The first audio 
packet of an audio stream in SEQ.2 contains the sample that has a 
presentation interval that includes the start of the presentation period of 
the first video picture in SEQ.2. This definition means audio packets at the 
20 end of SEQ.1 and at the start of SEQ.2 may overlap in their delivery time: 
the required player behaviour in this case will be defined below. 

During playback of a sequence, while playing back a single 
sequence, data from only a single time-base is present in the STD buffers, 
with the STD model operating as for the P-STD model defined in ISO/IEC 
25 13818-1 (MPEG-2 Systems): in this way, continuous presentation of both 
audio and video can be guaranteed. 

During the transition from one sequence to another, it is likely that 
the time-base of SEQ.2 will not be the same as SEQ.1. It is required that 
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the presentation of video data will continue seamlessly. There may be an 
overlap OV in the presentation time of audio presentation units, as 
illustrated in Figure 8. 

In temis of handling time stamp discontinuities for the MPEG 
5 stream, with a jump from a first sequence to the bridge sequence and then 
on to the second sequence, there will be a change in the time-base of the 
SCR/DTS/PTS time-stamps recorded with the streams at the discontinuity 
where the two sequences meet in the middle of the bridge. Figure 9 
illustrates this anangement for the following example, with the bridge 
10 sequence B between first sequence A and second sequence C. In the 
example, each picture has a size in bytes given by An. 

Each picture has decoding and presentation time stamps based on 
the system clock DTSAn. PTSp^. 

Each picture has a value for DTS and PTS recorded in the bit- 
1 5 stream or inferred from previous values recorded in the bit-streamDTS'An. 
PTS'a„. 

Each picture has a start code that is delivered into the STD model 
at a time that can be derived from the recorded SCR values SCR'at,. 

Each picture has a start code as an actual time in the STD model at 
20 which data is delivered into the STD buffer SCR^n- 

The picture period is T. 
For sequence A: 

SCRAn=SCRAn and DTS'An= DTS^n 

applying for all pictures n (in other words, the system clock in the player 
25 and the time-base recorded in the stream are the same). In cases where 
this is not true (for example after a previous jump) they will differ by a 
constant. 

Considering the timing of video presentation, the presentation is 
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continuous without a gap through the connection. Using the following: 

the PTS in the bitstream of the last video presentation unit 
ofSEQ.1. 

the PTS in the bitstream of the first video presentation unit 
ofSEQ.2. 

the presentation period of the last video presentation unit of 
SEQ.1. 

10 Then the offset between the two time-bases, STC_delta, is calculated from 
data in the two bitstreams as follows: 

STC^delta + PTS^^t = PTS'end + Tpp 

Hence 

1 5 STC„delta = PT&^ - PTS^^ + Tpp 

Up until time, T^ (SCR^video_end). the time when the last video pack of 
SEQ.1 has completely entered the STC, input timing to the STD is 
determined by the SCR's of the packs in SEQ.1 and the STC. The 
20 remaining packs of SEQ.1 shall enter the STD at the mux_rate of SEQ.1, 
The time at which the last byte of SEQ.1 enters the buffer is T2. If N is the 
number of bytes in the trailing audio packets, then one of a number of 
possible calculation options would be to use: 

25 AT = T2 - Ti = N / mux_rate 

After time T2, input timing to the STD is determined by the time-base STC* 
and the SCR's of SEQ.2. where STC is calculated as follows: 



PTS' 



end 



5 PTS^, 



start 



'PP 
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STC = STC + SCR_delta 

Note that this definition of the input schedule creates an overlap in the 
5 delivery time of trailing audio access units of SEQ.1 and any leading audio 
access units of SEQ.2. There is no overlap or interleaving of the data 
between the two sequences. Video packs shall be constructed so that 
they do not overlap. Decoders require some additional audio buffering 
(about 1s) to handle the overiap in time-bases. 

10 In relation to buffering there are several situations to be considered. 

The most restrictive is when full compliance to the MPEG-2 PS STD 
model is required. A more relaxed consideration allows an increased 
(double-sized) buffer during the transitions, into the bridge sequence. For 
full STD compliance, MPEG PS has a requirement that data does not 

15 spend more than 1s in the STD buffer. Therefore Is after a jump it is 
known that the only data in the STD buffer comes from the new sequence. 

We can construct the delivery time (SCR) of the last byte of the last 
pack containing video data delivered from SEQ.1 by examining the SCR 
values of the packets of SEQ.1 and from mux_rate: in the following this 

20 value is SCR^video.end- Taking: 

SCR^video_end the valuB of STC measured as the last byte of the last 
video pack of SEQ.1 is delivered to the STD: it can be 
calculated from the SCRs in the pack headers of SEQ.1 and 
25 mux_rate. 

SCR*^video.start as the value of SCR coded in the first video pack of SEQ.2 

(measured in the time base of SEQ.2) 
SCR^^deo.start the value of SCR'^vkjeo.start projected onto the time-base of 
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SEQ.1 : this may be calculated as follows: 
SCRWstart = SCR'Wstart " STC.delta 

5 For the STD to be compliant across the jump two conditions are required, 
the first of which is delivery of trailing audio in SEQ.1 (followed by leading 
audio in SEQ.2) should be contained in the inten^al defined by SCR^video.end 
and SCR^vktecstait. as follows: 

1 0 SCR'video.end + AT^ < SCR'video.slart + ATb 

Note that ATb has been added to the inequality as a result of allowing 
leading audio packets in SEQ.2. To satisfy this inequality, it may be 
necessary to re-encode and/or remultiplex part of one or both sequences. 
15 The second required condition is that delivery of video from SEQ.1 
followed by video from SEQ.2, as defined by the SCRs in SEQ.1 and 
SCRs in SEQ.2 projected onto the same time-base, shall cause no video 
buffer overflow. 

Turning to the audio issues, and beginning with packet alignment, 
20 there is nonnally a substantial skew between the arrival times of 
concun-ently decoded audio and video (approximately >100ms on 
average). This means that, at the end of reading the last frame of video 
required from sequence A, another several frames of audio (and of course 
video unless it can be skipped) have to be read from the multiplexed 
25 stream. Either the jump must be delayed and the video stopped, or 
prefereably the audio must be remultiplexed into the bridge sequence. 
Refening to Figure 10, if video packet V4 contains the end of the last video 
picture before the jump, it is probable that audio packets A2, A3, A4 will 
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need to be extracted from sequence A and copied and remultiplexed into 
the bridge sequence. 

Tlie same situation applies with the jump back into sequence C 
after the bridge. The first audio frames reached are likely to be eariier in 
5 presentation time than the video at the jump point, but the audio must be 
continuous across the jump. Having chosen the jump point for video, it is 
necessary to make sure that the audio in the bridge sequence will match 
the audio in sequence C. 

In terms of audio gaps, because of the difference in audio and 

10 video frame duration, there will be breaks in the periodicity of audio 
framing at the point a seamless (in video) splice is made. This break is up 
to about 1 audio frame {24ms) in length, it will occur near the video frame ^ 
that marks the splice. Timing information in the play list would help the 
audio decoder to manage this break. ^ti 

15 At the disc allocation level, once the elementary streams and - 

multiplex requirements have been met, it is also necessary to ensure that ^ 
the bridge sequence is long enough so that it can be allocated to a ' 
contiguous range of addresses on the disc, and that the sections on either 
side of the bridge in sequence A and sequence C remain long enough. An 

20 example of this is described in our commonly assigned European patent 
application no. 98200888.0, filed 19th March 1998. The basic requirement 
is that for one particular disc configuration, the bridge sequence is 
between 2-4 Mbytes in length and that the parts of fragments on either 
side of the bridge remain longer than 2 Mbytes: this restriction is not, 

25 however, applicable to all cases. 

In the foregoing, we have described a means to address the 
problem of making video- and/or audio-frame accurate edits in MPEG- 
compliant and similar program streams where, because of the temporal 
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dependencies and buffering models used in MPEG and similar coding and 
multiplexing techniques, simple cut-and-paste edits cannot be made at any 
frame boundary. In order to facilitate editing, we generate bridge 
sequences - that is to say short sequences of coding-compliant data that 
5 are especially constructed (in the manner described above) to link together 
two original recordings of MPEG or similar data. 

From reading the present disclosure, other variations will be 
apparent to persons skilled in the art. Such variations may involve other 
10 features which are already known in the methods and apparatuses for 
editing of audio and/or video signals and component parts thereof and 
which may be used instead of or in addition to features already described 
herein. 



• 
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CLAIMS 

1. A data processing apparatus comprising means operable to 
read sequences of frame-based data from a storage device and to edit the 
5 same, such as to link from a first edit point in a first frame sequence to a 
second edit point in a second sequence, wherein for each of the stored 
frame sequences a number of the frames (hereinafter "l-firames") are 
intra-coded, without reference to any other frame of the sequence, a 
number (hereinafter "P-frames") are respectively coded with reference to 

10 one further frame of the sequence, and the remainder (hereinafter "B- 
frames") are respectively coded with reference to two or more further 
frames of the sequence; the apparatus including bridge generation means 
configured to create a bridge frame sequence to link the first and second 
edit points, by selective incorporation of frames from the stored first and 4 

1 5 second frame sequences and selective receding of one or more of the 
frames within the bridge sequence as determined by the coding type 
(I.P,B) of the frames from the first and second sequences indicated by the 
respective edit points. 

20 2. Apparatus as claimed in Claim 1, wherein the sequence 

frames are video image frames and the bridge generation means is 
configured to constmct the edited sequence with the jump from first 
sequence to bridge and from bridge to second sequence occurring at 
frame boundaries. 

25 

3. Apparatus as claimed in Claim 1. wherein the sequences 
comprise multiplexed arrangements of video image and audio data frames 
and the bridge generation means is arranged to present in the bridge 
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sequence all contributing video frames from the first sequence prior to the 
contributing video frames from the second sequence. 

4. Apparatus as claimed in Claim 3, wherein in the bridge 
5 sequence at the join between first and second sequence audio frames 
there is a gap of up to one audio frame in duration and the bridge 
generation means is arranged to insert an overiapping audio frame in this 

gap. 

10 5. Apparatus as claimed in Claim 1. wherein the bridge 

generation means is arranged to detect respective time stamps in the first 
and second sequences and includes means operable to derive a value 
specifying a discontinuity between the time stamps, to calculate an offset 
to be applied to time stamps of the second sequence to remove said 

1 5 discontinuity and to apply said offset to the second sequence. 

6. Apparatus as claimed in any of Claims 1 to 5, wherein the 
bridge generation means, on receiving specification of a target length for 
the bridge sequence, is arranged to vary the number of frames extracted 

20 from the first and/or second sequences such as to meet the target length. 

7. Apparatus as claimed in Claim 6, wherein the bridge 
generation means is arranged to shift the first and/or second edit points to 
result in the target length for the bridge sequence. 

25 

8. Apparatus as claimed in Claim 6, wherein the bridge 
generation means is arranged to selectively extract frames of the first 
sequence before the first edit point and/or frames of the second sequence 
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after the second edit point to result in the target length for the bridge 
sequence. 

9. Apparatus as claimed in Claim 1 , wherein the storage device 
5 is writable, the apparatus further comprising a device recording sub- 
system operable to write one or more sequences of frame-based data to 
storage locations on or within the storage device. 



10 as to link from a first edit point in a first frame sequence to a second edit 
point in a second sequence, wherein for each of the frame sequences a . 
number of the .firames (hereinafter "l-frames") are intra-coded. without ^ 
reference to any other frame of the sequence, a numben (hereinafter "P- - 
frames'^ are respectively coded with reference to one further frame of the - 

15 sequence, and the remainder (hereinafter "B-frames") are respectively 
coded with reference to two or more further frames of the sequence; the 
method including the step of creating a bridge frame sequence to link the mr 
first and second edit points, the bridge frame sequence incorporating v rrl f 
frames from the first and second frame sequences with selective receding 

20 of frames within the bridge sequence being determined by the coding type 
(l,P,B) of the frames from the first and second sequences indicated by the 
respective edit points. 

11. A method as claimed in Claim 10, wherein the sequence 
25 frames are video image frames and the edited sequence is constructed 
with the jump from first sequence to bridge and from bridge to second 
sequence occurring at frame boundaries. 



10. A method for editing sequences of frame-based data such 
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12. A method as claimed in Claim 10, wherein the sequences 
comprise multiplexed arrangements of video image and audio data 
frames, with presentation in the bridge sequence of all contributing video 
frames from the first sequence prior to the contributing video frames from 

5 the second sequence. 

13. A method as claimed in Claim 12. wherein in the bridge 
sequence at the join between first and second sequence audio frames 
there is a gap of up to one audio frame in duration which gap is filled by 

1 0 the insertion of an overiapping audio frame. 

14. A method as claimed in Claim 10 including the steps of 
detecting respective time stamps in the first and second sequences, 
deriving a value specifying a discontinuity between the time stamps. 

1 5 calculating an offeet to be applied to time stamps of the second sequence 
to remove said discontinuity, and application of said offset to the second 
sequence. 

15. A method as claimed in any of Claims 10 to 14, wherein the 
20 storage device is an optical disc and the location of the sequences of data 

thereon is indicated by a table of contents held by the disc. 

16. A method as claimed in Claim 10, wherein the frame 
indicated by the first edit point is a B-frame and the jump to the first frame 

25 of the bridge sequence is made on the nearest preceding P-frame in the 
display order of the first sequence. 

17. A method as claimed in Claim 16, wherein the first ft-ame of 
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the bridge sequence following the jump comprises a reference frame 
extracted from the second sequence followed by those B-frames of the 
first sequence up to the edit point, said B-frames having been re-encoded 
with reference to the reference frame. 

5 

18. A method as claimed in Claim 10, wherein the frame 
indicated by the first edit point is an l-firame or a P-frame and the jump to 
the first frame of the bridge sequence is made following the nearest 
preceding B-frame in the display order of the first sequence. 

10 

19. A method as claimed in Claim 10, wherein the frame 
indicated by the second edit point is a B-frame and the bridge sequence 
-frames preceding the jump to . the; second sequence comprise those 
second sequence firames from the nearest P-frame preceding the 

1 5 indicated frame in bit stream order and any intervening B-frames. , 

20. A method as claimed in Claim 10, wherein the frame 
indicated by the second edit point is a P-frame and the bridge sequence 
frame preceding the jump to the second sequence comprises the indicated 

20 P-frame. 

21. A method as claimed in Claim 19 or Claim 20, wherein the 
contents of a P-frame included prior to a jump from bridge sequence to 
second sequence are re-encoded in the bridge sequence as an l-frame. 

25 

22. A method as claimed in Claim 10, wherein the frame 
indicated by the second edit point is an l-frame and the bridge sequence 
frame preceding the jump to the second sequence comprises the indicated 
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l-frame. 

23. A storage device carrying a plurality of frame sequences 
together with one or more bridge sequences linking respective pairs of 
sequences at specified edit points and a table of contents identifying the 
respective storage address of each frame sequence and bridge sequence, 
the or each bridge sequence having been generated following the method 
of any of Claims 10 to 22. 
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